<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>外间距margin</title>
    <style>
        body{
            margin: 0;
        }
        .fu{
            background-color: rgba(255,255,0,.3);
            /*让父元素形成BFC结界，首尾子元素的外间距不会超出父元素的范围*/
            overflow: hidden;/*BFC清除浮动*/
        }
        .fu>div{
            width: 100px;
            height: 100px;
            background-color: rgba(0,0,255,0.6);
            border: 2px solid #00f;
            color: #fff;
        }
        /*相邻兄弟垂直方向的外间距取大值，不会叠加*/
        .z1{
            margin-top: 50px;
            margin-bottom: 30px;
        }
        .z2{
            margin-top: 50px;
        }
        .z3{
            margin: 10px;/*四个方向*/
            margin: 10px 20px;/*上下都是10, 左右20*/
            margin: 10px 20px 30px;/*上10 右20 下30 左20*/
            margin: 10px 20px 30px 40px;/*上10 右20 下30 左40*/
            margin: 0 auto;
        /*    实现块级元素自己的水平居中
            auto：自动将本元素的左右外间距计算成等值*/
        }
        .z4{
            margin-botton: 50px;
        }
        span{
            border: red solid 2px;
        }
        .s2{
        /*    行内元素垂直方向的外间距不生效*/
            margin: 30px;
        }
    </style>
</head>
<body>
<span>span1</span><span class="s2">span2</span><span>span3</span>
<!--.fu>.z*4-->
<div class="fu">
    <div class="z1">子元素1</div>
    <div class="z2">子元素2</div>
    <div class="z3">子元素3</div>
    <div class="z4">子元素4</div>
</div>


</body>
</html>